body {
	margin: 0;
	width: 100vw;
	height: 100vh;
	overflow: hidden;
	position: relative;
	background-color: rgb(36, 74, 101);
}

.tools {
	position: absolute;
	top: -80px;
	left: 50%;
	width: 70%;
	height: 100px;
	transform: translateX(-50%);
	background-color: lightcoral;
	transition: all 0.5s ease-in-out;
	border-radius: 0 0 15px 15px;
	display: flex;
	align-items: center;
	justify-content: center;
	user-select: none;
}

.tools img {
	transition: all 0.5s;
}

.tools .arrow {
	width: 20px;
	height: 20px;
	position: absolute;
	bottom: 0;
	left: 50%;
	transform: translateX(-50%);
}

.tools:hover {
	transform: translate(-50%, 80px);
}

.tools:hover .arrow {
	transform: rotate(180deg) translateX(50%);
}

.eraser,
.brush,
.clean,
.save,
.undo,
.redo {
	display: inline-block;
	width: 40px;
	height: 40px;
	padding: 5px;
	display: flex;
	justify-content: center;
	align-items: center;
}

.tools .clean {
	transition: all 0.5s ease-in-out;
}

.tools .clean:hover {
	transform: rotate(-45deg);
}

.tools .save {
	transition: all 0.5s ease-in-out;
}

.tools .save:hover {
	transform: rotate(45deg);
}

.active {
	transform: scale(1.3);
}

.side {
	width: 100px;
	height: 70%;
	background-color: lightcoral;
	position: absolute;
	right: -80px;
	top: 50%;
	transform: translateY(-50%);
	border-radius: 15px 0 0 15px;
	transition: all 0.5s ease-in-out;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
}

.side:hover {
	transform: translate(-80px, -50%);
}

.side .left-arrow {
	width: 20px;
	height: 20px;
	position: absolute;
	left: 2px;
	top: 10px;
	transition: all 0.5s ease-in-out;
}

.side img {
	display: block;
	width: 60px;
	margin: 10px 0;
}

.side:hover .left-arrow {
	transform: rotate(180deg);
}
